<template>
  <h1>SPU管理</h1>
  <div>
    <el-card style="margin: 20px 0px">
      <!-- 三级联动已经是全局组件了 -->
      <CategorySelect :show="scene != 0" @getCategoryId="getCategoryId" />
    </el-card>
    <el-card>
      <!-- 底部这里将来是有三部分进行切换 -->
      <div v-show="scene == 0">
        <!-- 展示SPU列表的结构 -->
        <el-button
          type="primary"
          icon="plus"
          :disabled="!category3Id"
          style="margin-bottom: 10px;"  
          @click="addSpu"
          >添加SPU</el-button
        >
        <el-table style="width: 100%" border :data="records">
          <el-table-column
            type="index"
            label="序号"
            width="80"
            align="center"
          />
          <el-table-column prop="spuName" label="SPU名称" width="width" />
          <el-table-column prop="description" label="SPU描述" width="width" />
          <el-table-column prop="prop" label="操作" width="width">
            <template v-slot="{ row }">
              <!-- 这里按钮将来用hintButton替换 -->
              <el-button
                type="success"
                icon="plus"
                title="添加sku"
                @click="addSku(row)"
              />
              <el-button
                type="warning"
                icon="edit"
                title="修改spu"
                @click="updateSpu(row)"
              />
              <el-button
                type="info"
                icon="infoFilled"
                title="查看当前spu全部sku列表"
                @click="handler(row)"
              />
              <el-popconfirm
                title="这是一段内容确定删除吗？"
                @onConfirm="deleteSpu(row)"
              >
                <template #reference>
                  <el-button type="danger" icon="delete" title="删除spu" />
                </template>
              </el-popconfirm>
            </template>
          </el-table-column>
        </el-table>
        <el-pagination
          style="text-align: center"
          :current-page="page"
          :page-sizes="[3, 5, 10]"
          :page-size="limit"
          layout="prev, pager, next, jumper,->, sizes,total"
          :total="total"
          @current-change="getSpuList"
          @size-change="handleSizeChange"
        />
      </div>
      <SpuForm v-show="scene == 1" ref="spu" @changeScene="changeScene" />
      <SkuForm v-show="scene == 2" ref="sku" @changeScenes="changeScenes" />
    </el-card>


    <!-- 对话框 -->
    <el-dialog
      :title="`${spu.spuName}的sku列表`"
      v-model="dialogTableVisible"
      :before-close="close"
    >
      <!-- table展示sku列表-->
      <el-table v-loading="loading" :data="skuList" style="width: 100%" border>
        <el-table-column prop="skuName" label="名称" width="width" />
        <el-table-column prop="price" label="价格" width="width" />
        <el-table-column prop="weight" label="重量" width="width" />
        <el-table-column label="默认图片" width="width">
          <template v-slot="{ row }">
            <el-image
              :src="row.skuDefaultImg"
              style="width: 100px; height: 100px"
            />
          </template>
        </el-table-column>
      </el-table>
    </el-dialog>
  </div>
</template>

<script>
// 引入子组件
import SpuForm from "./spu/SpuForm";
import SkuForm from "./spu/SkuForm";
export default {
  name: "SpuIndex",
  components: {
    SpuForm,
    SkuForm,
  },
  data() {
    return {
      // 分别是分类的id
      category1Id: "",
      category2Id: "",
      category3Id: "",
      // 控制三级联动的可操作性
      page: 1, // 分页器当前第几页
      limit: 3, // 每一页需要展示多少条数据
      records: [], // spu列表的数据
      total: 0, // 分页器一共需要展示数据的条数
      scene: 0, // 0代表展示SPU列表数据   1 添加SPU|修改SPU   2 添加SKU
      // 控制对话框的显示与隐藏
      dialogTableVisible: false,
      spu: {},
      skuList: [], // 存储的是SKU列表的数据
      loading: true,
    };
  },
  methods: {
    // 三级联动的自定义事件，可以把子组件的相应的id传递给父组件
    getCategoryId({ categoryId, level }) {
      // categoryId:获取到一、二、三级分类的id  level：为了区分是几级id
      if (level === 1) {
        this.category1Id = categoryId;
        // 清除2、3级分类的id
        this.category2Id = "";
        this.category3Id = "";
      } else if (level === 2) {
        this.category2Id = categoryId;
        // 清除3级id
        this.category3Id = "";
      } else {
        this.category3Id = categoryId;
        // 获取SPU列表数据进行展示
        this.getSpuList();
      }
    },

    // 获取SPU列表数据的方法
    async getSpuList(pages = 1) {
      this.page = pages;
      const { page, limit, category3Id } = this;
      // 携带三个参数:page 第几页  limit 每一页需要展示多少条数据  三级分类id
      const result = await this.$API.spu.reqSpuList(page, limit, category3Id);
      if (result.code === 200) {
        this.total = result.data.total;
        this.records = result.data.records;
      }
    },

    // 当分页器的某一个展示数据条数发生变化的回调
    handleSizeChange(limit) {
      // 修改参数
      this.limit = limit;
      // 再发请求
      this.getSpuList();
    },

    // 添加SPU按钮的回调
    addSpu() {
      // 切换为场景为1
      this.scene = 1;
      // 通知子组件SpuForm发请求---两个
      this.$refs.spu.addSpuData(this.category3Id);
    },

    // 修改某一个SPU
    updateSpu(row) {
      this.scene = 1;
      // 获取子组件SpuForm子组件的
      // 在父组件当中可以通过$ref获取子组件等等
      this.$refs.spu.initSpuData(row);
    },

    // 自定义事件回调（SpuForm）
    changeScene({ scene, flag }) {
      // flag这个形参为了区分保存按钮是添加还是修改
      // 切换结构（场景）
      this.scene = scene;
      // 子组件通知父组件切换场景，需要再次获取SPU列表的数据进行展示
      if (flag === "修改") {
        this.getSpuList(this.page);
      } else {
        this.getSpuList();
      }
    },

    // skuform通知父组件修改场景
    changeScenes(scene) {
      this.scene = scene;
    },

    // 删除SPU的回调
    async deleteSpu(row) {
      const result = await this.$API.spu.reqDeleteSpu(row.id);
      if (result.code === 200) {
        this.$message({ type: "success", message: "删除成功" });
        // 代表SPU个数大于1删除的时候停留在当前页，如果SPU个数小于1 回到上一页
        this.getSpuList(this.records.length > 1 ? this.page : this.page - 1);
      }
    },

    // 添加SKU按钮的回调
    addSku(row) {
      // 切换场景为2
      this.scene = 2;
      // 父组件调用子组件的方法，让子组件发请求------三个请求
      this.$refs.sku.getData(this.category1Id, this.category2Id, row);
    },

    // 查看SKU的按钮的回调
    async handler(spu) {
      // 点击这个按钮的时候，对话框可见的
      this.dialogTableVisible = true;
      // 保存spu信息
      this.spu = spu;
      // 获取sku列表的数据进行展示
      const result = await this.$API.spu.reqSkuList(spu.id);
      if (result.code === 200) {
        this.skuList = result.data;
        console.log(this.skuList);
        // loading隐藏
        this.loading = false;
      }
    },

    // 关闭对话框的回调
    close(done) {
      // loading属性再次变为真
      this.loading = true;
      // 清除sku列表的数据
      this.skuList = [];
      // 管理对话框
      done();
    },

    
  },
};
</script>

<style scoped>
h1 {
  margin: 10px 0px;
  font-size: 24px;
  color: #0a279b;
  font-weight: bold;
}

</style>